

**What is claimed is:**

1. An apparatus comprising:
  - 2 a data input;
  - 3 a data output;
  - 4 a multiplexer have a plurality of inputs and an output coupled to said data output, and having a control input for receiving a switching control signal;
  - 5 a comparator having a plurality of data inputs and having a reference bit pattern, and having one primitive present output corresponding to each data input, said comparator functioning to compare the data at each input to said reference bit pattern and activate a primitive present signal on the output corresponding to each of said data inputs at which data appears which matches said reference bit pattern;
  - 6 a plurality of data registers having data inputs coupled to said data input, each said data register having a data output coupled to one of said inputs of said multiplexer, and to one of said inputs of said comparator, each said data register having an address input for receiving a select input signal, which when active, will cause said data register to store the data then existing on said data input;
  - 7 a receive clock input for receiving a receive clock signal;
  - 8 a transmit clock input for receiving a transmit clock signal;
  - 9 an insertion/deletion control unit having a plurality of inputs coupled to receive said primitive present signals from said comparator, and having a transmit address input for receiving a transmit address signal and a receive address input for receiving a receive address signal, and having a switching control output coupled to supply said switching control signal to said control input of said multiplexer, and having a delete output at which a Delete signal appears, and having an insert output at which an Insert signal appears, and having logic for comparing a transmit address to said receive address and activating said Delete signal when the difference between said transmit address and said receive address is greater than the number of data registers divided by two, and for activating said Insert signal when the difference between said transmit address and said receive address is less than the number of data registers divided by two, said transmit address controlling which of said outputs of said data registers is coupled through said multiplexer to said data output, and said receive address controlling which of said data registers stores the data currently at

32           said data input;

33           a receive address counter having a clock input coupled to said receive clock

34           signal and having an address output coupled to each of said address inputs of said

35           plurality of data registers for generating said select input signals for said data

36           registers in sequence as said receive clock increments, and having receive address

37           output coupled to said receive address input of said insertion/deletion control unit to

38           supply said receive address signal thereto;

39           a transmit address counter having a clock input coupled to receive said

40           transmit clock signal, and having a transmit address output coupled to said transmit

41           address input of said insertion/deletion logic to supply said transmit address signal

42           to said insertion/deletion logic for supplying by said insertion/deletion logic to said

43           multiplexer as said switching control signal, and having an input for receiving a

44           Delete signal and an input for receiving an Insert signal, said transmit address

45           counter configured skip the address in the sequence of address increments that

46           corresponds to the address of the data register in which a deletable primitive is

47           stored when said delete signal is activated and configured to dwell on the address that

48           corresponds to the address of the data register in which a deletable non essential

49           primitive or other non essential data is stored for at least one extra clock cycle of

50           said transmit clock when said Insert signal is activated.

1       2. An apparatus comprising:

2           means for receiving at a receive clock rate a stream of serial format data

3           including data words and primitives which can be deleted without adverse effects,

4           hereafter called nonessential primitives, and/or other nonessential data and storing

5           said received data in a first in, first out buffer, each data word, primitive and piece

6           of nonessential data stored at a different address;

7           means for transmitting at a transmit clock rate the data words, primitives

8           and nonessential data stored in said FIFO at selected addresses;

9           means for determining which addresses in said FIFO store primitives or

10           nonessential data that can be deleted;

11           means for comparing a transmit address pointer in said FIFO which is

12           incremented at said transmit clock rate to a receive address pointer in said FIFO

13        which is incremented at said receive clock rate and, when the distance between said  
14        pointers indicates the possibility of overflow or underflow, controlling said means  
15        for transmitting so as to insert nonessential primitives or other nonessential data or  
16        to delete nonessential primitives or other nonessential data appropriately to avert  
17        either overflow or underflow.

1        3. A process for preventing overflow or underflow in serial data transmission protocols  
2        with separate transmit and receive clocks which may be running at different frequencies,  
3        comprising the steps of:

4            receiving at a receive clock rate a stream of serial format data including data  
5        words and primitives which can be deleted without adverse effects, hereafter called  
6        nonessential primitives, and/or other nonessential data and storing said received  
7        data in a first in, first out buffer, each data word, primitive and piece of  
8        nonessential data stored at a different address;

9            transmitting at a transmit clock rate the data words, primitives and  
10        nonessential data stored in said FIFO at selected addresses;

11            determining which addresses in said FIFO store primitives or nonessential  
12        data that can be deleted;

13            comparing a transmit address pointer in said FIFO which is incremented at  
14        said transmit clock rate to a receive address pointer in said FIFO which is  
15        incremented at said receive clock rate and, when the distance between said pointers  
16        indicates the possibility of overflow or underflow, controlling said means for  
17        transmitting so as to insert nonessential primitives or other nonessential data or to  
18        delete nonessential primitives or other nonessential data appropriately to avert  
19        either overflow or underflow.